552E - Vanya and Brackets - CodeForces Solution


brute force dp expression parsing greedy implementation strings *2100

Please click on ads to support us..

Python Code:

expr = list(input())
mul_pos = [-1]
add_cnt = [0] * len(expr)
for i, _ in enumerate(expr):
    add_cnt[i] = add_cnt[i - 1]      if _ == '*':
        mul_pos.append(i)
    elif _ == '+':
        add_cnt[i] += 1
mul_pos.append(len(expr))
add_cnt.append(add_cnt[-1])
add_cnt.append(0)
ans = 0
for i in range(len(mul_pos)):
    for j in range(i + 1, len(mul_pos)):
        if add_cnt[mul_pos[i]] - add_cnt[mul_pos[j]]:
            expr.insert(mul_pos[i] + 1, '(')
            expr.insert(mul_pos[j] + 1, ')')
                        ans = max(ans, eval(''.join(expr)))
            expr.pop(mul_pos[j] + 1)
            expr.pop(mul_pos[i] + 1)
print(eval(''.join(expr)) if ans == 0 else ans)


Comments

Submit
0 Comments
More Questions

580A- Kefa and First Steps
1472B- Fair Division
996A - Hit the Lottery
MSNSADM1 Football
MATCHES Playing with Matches
HRDSEQ Hard Sequence
DRCHEF Doctor Chef
559. Maximum Depth of N-ary Tree
821. Shortest Distance to a Character
1441. Build an Array With Stack Operations
1356. Sort Integers by The Number of 1 Bits
922. Sort Array By Parity II
344. Reverse String
1047. Remove All Adjacent Duplicates In String
977. Squares of a Sorted Array
852. Peak Index in a Mountain Array
461. Hamming Distance
1748. Sum of Unique Elements
897. Increasing Order Search Tree
905. Sort Array By Parity
1351. Count Negative Numbers in a Sorted Matrix
617. Merge Two Binary Trees
1450. Number of Students Doing Homework at a Given Time
700. Search in a Binary Search Tree
590. N-ary Tree Postorder Traversal
589. N-ary Tree Preorder Traversal
1299. Replace Elements with Greatest Element on Right Side
1768. Merge Strings Alternately
561. Array Partition I
1374. Generate a String With Characters That Have Odd Counts